# **CPU Architecture**

LAB1 preparation report

VHDL part1 – Concurrent code

**Hanan Ribo** 

06/05/2024

# Table of contents

| 1. | Aim of the Laboratory                                                 | 3 |
|----|-----------------------------------------------------------------------|---|
|    | System Design ISA                                                     |   |
| 3. | Status Bits                                                           | 4 |
| 4. | System Design Micro-Architecture                                      | 5 |
|    | Generic Adder/Subtractor module based on a single ripple carry adder: |   |
| 6. | Shifter Module based on a single Barrel-Shifter n-bit:                | 7 |
| 7. | Test and Timing:                                                      | 7 |
| 8. | System Output Example (for n=8)                                       | 8 |
|    | Requirements                                                          |   |
|    | Grading Policy                                                        |   |

### 1. Aim of the Laboratory

- Obtaining skills in VHDL part1 code, which contains Code Structure, Data Types,
   Operators and Attributes, Concurrent Code, Design Hierarchy, Packages and
   Components.
- Obtaining basic skills in ModelSim (multi-language HDL simulation environment).
- General knowledge rehearsal in digital systems.
- Proper analysis and understanding of architecture design.

# 2. System Design ISA

| Function   | Decimal | ALUFN         | Operation             | Note                             |
|------------|---------|---------------|-----------------------|----------------------------------|
| Kind       | value   |               |                       |                                  |
| Arithmetic | 8       | <b>01</b> 000 | Res=Y+X               |                                  |
|            | 9       | <b>01</b> 001 | Res=Y-X               | Used also for compare operation  |
|            | 10      | <b>01</b> 010 | Res=neg(X)            |                                  |
| Shift      | 16      | 10000         | Res=SHL Y,X(k-1 to 0) | Shift Left Y of q≜X(k-10) times  |
|            |         |               |                       | Res=Y(n-1-q0)#(q@0)              |
|            |         |               |                       | When $k = log_2 n$               |
|            | 17      | <b>10</b> 001 | Res=SHR Y,X(k-1 to 0) | Shift Right Y of q≜X(k-10) times |
|            |         |               |                       | Res = (q@0) # Y(n-1q)            |
|            |         |               |                       | When $k = log_2 n$               |
| Boolean    | 24      | <b>11</b> 000 | Res=not(Y)            |                                  |
|            | 25      | <b>11</b> 001 | Res=Y or X            |                                  |
|            | 26      | <b>11</b> 010 | Res=Y and X           |                                  |
|            | 27      | <b>11</b> 011 | Res=Y xor X           |                                  |
|            | 28      | <b>11</b> 100 | Res=Y nor X           |                                  |
|            | 29      | <b>11</b> 101 | Res=Y nand X          |                                  |
|            | 30      | <b>11</b> 111 | Res=Y xnor X          |                                  |

**Table 1: Selected operations** 

# 3. Status Bits

| Status Bit | Description                                                                                                                                                                                                    |  |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| V          | Overflow bit. This bit is set when the result of an arithmetic operation overflows the signed-variable range.  1. In case of ADD operation: V=1: Positive + Positive = Negative Negative + Negative = Positive |  |
|            | otherwise, V=0.                                                                                                                                                                                                |  |
|            | <ul> <li>2. In case of SUB operation:</li> <li>V=1:</li> <li>Positive - Negative = Negative</li> <li>Negative - Positive = Positive otherwise, V=0.</li> </ul>                                                 |  |
|            | <u>Note</u> : It is mandatory to first manually write an optimized Boolean equation for V flag using above terms before its implementation.                                                                    |  |
| Z          | Zero bit. This bit is set when the result is 0 and cleared when the result is not 0.                                                                                                                           |  |
| С          | Carry bit. This bit is set when the result produced a carry and cleared when no carry occurred.                                                                                                                |  |
| N          | Negative bit. This bit is set when the result is negative and cleared when the result is not negative.                                                                                                         |  |

**Table 2: Status Bits details** 

#### 4. System Design Micro-Architecture

In this laboratory you will design a module which contains the next three sub-modules:

- Generic Adder/Subtractor module between two vectors Y, X of size n-bit (the default is n=8).
- Generic Shifter module based on Barrel-Shifter n-bit size (the default is n=8).
- Boolean Logic operates bitwise.
- The generic n value must be verified for 4,8,16,32 (set from *tb.vhd* file).
- You are required to design the whole system and make a test bench for testing.



The Top Level design must be Structural (your DUT must contain the exact



- Note: in the given two files top.vhd, aux\_package.vhd (you can only add code to these files, you are not allowed to erase anything).
- The submitted project must be compiled using the given **tb\_ref1.vhd** file (otherwise the submitted project will be considered as a failure).
- The submitted assignments get through copy checking machine, in this case,
   both sides' assignments will be disqualified.

# 5. Generic Adder/Subtractor module based on a single ripple carry adder:

- You are required to design a Generic Adder/Subtractor between two vectors Y, X of size n-bit (the default is n=8), using the next diagram. The design must be Structural of a least two levels.
- In order to do so, you are asked to use the Generic Adder code that was given in Moodle.



<u>Note:</u> this figure illustrates  $Y \pm X$  operation



Figure 2: Generic Adder/Subtractor (based on a single ripple carry adder)

#### 6. Shifter Module <u>based on a single Barrel-Shifter</u> n-bit:

<u>Note:</u> using sll, srl operators are forbidden and causes to disqualification of this clause. <u>Hint:</u> In order to meet the requirements you must use *generate* concurrent statement



Figure 3: Example of 8-bit Barrel Shifter

#### 7. Test and Timing:

- Design a test bench which tests all the system.
- Analyze the results by zooming on the important transactions in the waveforms.
   explain these (input/output/internal signals of the system).
- You are welcome to use the Internet also as reference.
- Good tip for beginners: Build a test bench for each module you are designing for easy debugging, otherwise you will waste a lot of time for whole system debug.
- The timing of the system will be ideal (means a functional simulation).

#### 8. System Output Example (for n=8)

Signal vectors are shown in binary format



Signals Y, X,ALUFN, ALUout are shown in HEX format (the same exact example as above).



In addition, you are given two test bench files *tb\_ref1.vhd*, *tb\_ref2.vhd* (in TB folder) and their associate do and list files (in SIM folder).



In order to use golden model based functional verification, you are given <u>TextDiff</u> application (download and double click the *TextDiff.exe* file) in order to compare your developing design results to the golden model results as part of design developing chain.



# Automatic Testbench

#### The DUT output is compared against the golden model



<u>Note:</u> in comparison between the given *tb\_ref1.lst*, *tb\_ref2.lst* files and yours, you should ignore the *delta cycle* column

#### 9. Requirements

- 1. The lab assignment is in pairs (as shown in the inlay file).
- 2. The design must be well commented.
- 3. **Important:** For each of two submodules:
  - Graphical description (a square with ports going in and out) and short descriptions.
- 4. Elaborated analysis and wave forms:
  - Remove irrelevant signals.
  - Zoom on regions of interest.
  - Draw clouds on the waveform with explanations of what is happening (Figure 4).
  - Change the waveform colors in ModelSim for clear documentation (Tools->Edit Preferences->Wave Windows).
- 5. A ZIP file in the form of **id1\_id2.zip** (where id1 and id2 are the identification number of the submitters, and id1 < id2) *must be upload to Moodle only by student with id1* (any of these rules violation disqualify the task submission).

#### 6. The **ZIP** file will contain (only the exact next sub folders):

| Directory | Contains                               | Comments                                           |
|-----------|----------------------------------------|----------------------------------------------------|
| DUT       | Project VHDL files                     | Only VHDL files of DUT, excluding test bench       |
|           |                                        | Note: your project files must be well              |
|           |                                        | compiled without errors as a basic condition       |
|           |                                        | before submission                                  |
| ТВ        | Four VHDL files that are used for test | AdderSub, Logic, shifter, System (top)             |
|           | bench                                  |                                                    |
| SIM       | Four ModelSim DO files (wave, list)    | AdderSub, Logic, shifter, System (top)             |
| DOC       | Project documentation                  | • readme.txt (list of the DUT *.vhd files with     |
|           |                                        | their brief functional description)                |
|           |                                        | • <i>pre1.pdf</i> (report file that includes brief |
|           |                                        | explanation of the four modules with their         |
|           |                                        | wave diagrams as shown in figure 4)                |

**Table 2: Directory Structure** 



Figure 4: Clouds over the waveform

# 10. Grading Policy

| Weight | Task              | Description                                                                                                      |
|--------|-------------------|------------------------------------------------------------------------------------------------------------------|
| 10%    | Documentation     | The "clear" way in which you presented the requirements and the analysis and conclusions on the work you've done |
| 90%    | Analysis and Test | The correct analysis of the system (under the requirements)                                                      |

Table 1 : Grading

Under the above policies you'll be also evaluated using common sense:

- Your files will be compiled and checked, the system must work.
- Your design and architecture must be intelligent, minimal, effective and well organized.

For a late submission the penalty is 2<sup>days</sup>